#include "comm.hpp"

Init init; 

string TransToHex(key_t k)
{
    char buffer[32];
    snprintf(buffer, sizeof buffer, "0x%x", k);
    return buffer;
}

int main()
{
    // 之前为了通信所做的所有的工作:让不同的进程看到了同一份资源(内存)
    // 1.创建公共的Key值
    key_t k = ftok(PATH_NAME, PROJ_ID);
    assert(k!=-1);
    
    Log("create key done", Debug) << " server key : " << TransToHex(k) << endl;

    // 2.创建共享内存 —— 建议要创建一个全新的共享内存 —— 通信的发起者
    int shmid = shmget(k, SHM_SIZE, IPC_CREAT | IPC_EXCL | 0666);
    if (shmid == -1)
    {
        perror("shmget");
        exit(1);
    }
    Log("create shm done", Debug) << " shmid : " << k << endl;
    //sleep(10);

    // 3.将指定的共享内存，挂接到自己的地址空间
    char *shmaddr = (char*)shmat(shmid, nullptr, 0);
    Log("attach shm done", Debug) << " shmid : " << shmid << endl;
    //sleep(10);

    // 这里就是通信的逻辑了

    int fd = OpenFIFO(FIFO_NAME, READ);
    for(;;)
    {
        Wait(fd);

        // 临界区
        printf("%s\n", shmaddr);
        if(strcmp(shmaddr, "quit") == 0) break;
        //sleep(1);
    }

    // 4. 将指定的共享内存，从自己的地址空间中去关联
    int n = shmdt(shmaddr);
    assert(n!=-1);
    (void)n;
    Log("detach shm done", Debug) << " shmid : " << shmid << endl;
    // sleep(10);

    // 5. 删除共享内存，IPC_RMID即便是有进程和当下的shm挂接，依旧删除共享内存
    n=shmctl(shmid, IPC_RMID, nullptr);
    assert(n!=-1);
    (void)n;
    Log("delete shm done", Debug) << " shmid : " << k << endl;

    CloseFifo(fd);
    return 0;
}